package com.cskaoyan.connectionpool;

import com.cskaoyan.util.JDBCUtils;
import com.mysql.jdbc.JDBC4Connection;

import java.sql.Connection;
import java.util.LinkedList;

/**
 * 创建日期: 2022/07/27 11:48
 *
 * @author ciggar
 *
 * 自己实现的数据库连接池（第一个版本）
 */
public class MyConnectionPoolV1 {

    // 维护一个容器 这个容器里面放的是连接对象
    // 从头部存，从尾部取
    static LinkedList<Connection> pool;

    static {

        // 初始化数据库连接池

        // 1. 创建实例对象
        pool = new LinkedList<>();

        // 2. 给连接池添加连接
        for (int i = 0; i < 10; i++) {

            Connection connection = JDBCUtils.getConnection();
            pool.addFirst(connection);
        }

    }



    // 获取连接
    public static Connection getConnection(){
        Connection connection = pool.removeLast();
        return connection;
    }



    // 回收连接
    public static void recyleConnection(Connection connection){
        pool.addFirst(connection);
    }


}
